﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.SqlClient;

namespace Axe.Extensions
{
    public static class SqlExtensions
    {
        /// <summary>
        /// Безопасный откат транзакции, связанной с данным объектом SqlCommand
        /// </summary>
        /// <param name="cmd"></param>
        public static void SafeTransactionRollback(this SqlCommand cmd)
        {
            if (cmd.Transaction != null)
                cmd.Transaction.SafeRollback();
        }

        /// <summary>
        /// Безопасный откат указанной транзакции
        /// </summary>
        /// <param name="transaction"></param>
        public static void SafeRollback(this SqlTransaction transaction)
        {
            try
            {
                transaction.Rollback();
            }
            catch { }
        }
    }
}
